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5 

METHOD AND APPARATUS FOR ENTERING DATA 
USING A VIRTUAL INPUT DEVICE 

10 

RELATION TO PREVIOUSLY FILED APPLICATION 
Priority is claimed from U.S. provisional patent application, serial number 
60/163,445, filed on 4 November 1999 and entitled "Method and Device for 3D 
Sensing of Input Commands to Electronic Devices", in which applicants herein 
1 5 were applicants therein. Said provisional patent application, which was assigned 
to Canasta, Inc., assignee herein, is incorporated herein by reference. 

Reference is also made to applicant Cyrus Bamji's co-pending U.S. patent 
application serial number 09/401,059 filed on 22 September 1999, entitled 
20 "CMOS-COMPATIBLE THREE-DIMENSIONAL IMAGE SENSOR IC" and 
assigned to Canasta, Inc., the common assignee herein. Said co-pending U.S. 
patent application is also incorporated herein by reference. 

FIELD OF THE INVENTION 

25 The invention relates generally to inputting commands and/or data (collectively, 
referred to herein as "data") to electronic systems including computer systems. 
More specifically, the invention relates to methods and apparatuses for inputting 
data when the form factor of the computing device precludes using normally 
sized input devices such as a keyboard, or when the distance between the 

30 computing device and the input device makes it inconvenient to use a 
conventional input device coupled by cable to the computing device. 

BACKGROUND OF THE INVENTION 
Computer systems that receive and process input data are well known in the art. 
35 Typically such systems include a central processing unit (CPU), persistent read 
only memory (ROM), random access memory (RAM), at least one bus 
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interconnecting the CPU, the memory, at least one input port to which a device 
is coupled input data and commands, and typically an output port to which a 
monitor is coupled to display results. Traditional techniques for inputting data 
have included use of a keyboard, mouse, joystick, remote control device, 
5 electronic pen, touch panel or pad or display screen, switches and knobs, and 
more recently handwriting recognition, and voice recognition. 

Computer systems and computer-type systems have recently found their way 
into a new generation of electronic devices including interactive TV, set-top 
1 0 boxes, electronic cash registers, synthetic music generators, handheld portable 
devices including so-called personal digital assistants (PDA), and wireless 
telephones. Conventional input methods and devices are not always appropriate 
or convenient when used with such systems. 

1 5 For example, some portable computer systems have shrunk to the point where 
the entire system can fit in a user's hand or pocket. To combat the difficulty in 
viewing a tiny display, it is possible to use a commercially available virtual display 
accessory that clips onto an eyeglass frame worn by the user of the system. The 
user looks into the accessory, which may be a 1" VGA display, and sees what 

20 appears to be a large display measuring perhaps 15" diagonally. 

Studies have shown that use of a keyboard and/or mouse-like input device is 
perhaps the most efficient technique for entering or editing data in a companion 
computer or computer-like system. Unfortunately it has been more difficult to 

25 combat the problems associated with a smaller size input device, as smaller 
sized input devices can substantially slow the rate with which data can be 
entered. For example, some PDA systems have a keyboard that measures 
about 3" x 7". Although data and commands may be entered into the PDA via 
the keyboard, the entry speed is reduced and the discomfort level is increased, 

30 relative to having used a full sized keyboard measuring perhaps 6" x 12". Other 
PDA systems simply eliminate the keyboard and provide a touch screen upon 
which the user writes alphanumeric characters with a stylus. Handwriting 
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recognition software wrhin the PDA then attempts to interpret and recognize 
alphanumeric characters drawn by the user with a stylus on a touch sensitive 
screen. Some PDAs ca n display an image of a keyboard on a touch sensitive 
screen and permit users to enter data by touching the images of various keys 
5 with a stylus. In other systems, the distance between the user and the computer 
system may preclude a convenient use of wire-coupled input devices, for 
example the distance between a user and a set-top box in a living room 
environment precludes use of a wire-coupled mouse to navigate. 

1 0 Another method of data and command input to electronic devices is recognizing 
visual images of user actions and gestures that are then interpreted and 
converted to commands for an accompanying computer system. One such 
approach was described in U.S. Patent no. 5,767,842 to Korth (1998) entitled 
"Method and Device for Optical Input of Commands or Data". Korth proposed 

15 having a computer system user type on an imaginary or virtual keyboard, for 
example a keyboard-sized piece of paper bearing a template or a printed outline 
of keyboard keys. The template is used to guide the user's fingers in typing on 
the virtual keyboard keys. A conventional TV (two-dimensional) video camera 
focused upon the virtual keyboard was stated to somehow permit recognition of 

20 what virtual key (e.g., printed outline of a key) was being touched by the user's 
fingers at what time as the user "typed" upon the virtual keyboard. 

But Korth's method is subject to inherent ambiguities arising from his reliance 
upon relative luminescence data, and indeed upon an adequate source of 

25 ambient lighting. While the video signal output by a conventional two- 
dimensional video camera is in a format that is appropriate for image recognition 
by a human eye, the signal output is not appropriate for computer recognition of 
viewed images. For example, in a Korth-type application, to track position of a 
user's fingers, computer-executable software must determine contour of each 

30 finger using changes in luminosity of pixels in the video camera output signal. 
Such tracking and contour determination is a difficult task to accomplish when 
the background color or lighting cannot be accurately controlled, and indeed may 
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resemble the user's fingers. Further, each frame of video acquired by Korth, 
typically at least 100 pixels x 100 pixels, only has a grey scale or color scale 
code (typically referred to as RGB). Limited as he is to such RGB value data, a 
microprocessor or signal processor in a Korth system at best might detect the 
5 contour of the fingers against the background image, if ambient lighting 
conditions are optimal. 

The attendant problems are substantial as are the potential ambiguities in 
tracking the user's fingers. Ambiguities are inescapable with Korth's technique 

1 0 because traditional video cameras output two-dimensional image data, and do 
not provide unambiguous information about actual shape and distance of objects 
in a video scene. Indeed, from the vantage point of Korth's video camera, it 
would be very difficult to detect typing motions along the axis of the camera lens. 
Therefore, multiple cameras having different vantage points would be needed to 

1 5 adequately capture the complex keying motions. Also, as suggested by Korth's 
Fig. 1 , it can be difficult merely to acquire an unobstructed view of each finger on 
a user's hands, e.g., acquiring an image of the right forefinger is precluded by the 
image-blocking presence of the right middle finger, and so forth. In short, even 
with good ambient lighting and a good vantage point for his camera, Korth's 

20 method still has many shortcomings, including ambiguity as to what row on a 
virtual keyboard a user's fingers is touching. 

In an attempt to gain depth information, the Korth approach may be replicated 
using multiple two-dimensional video cameras, each aimed toward the subject 

25 of interest from a different viewing angle. Simple as this proposal sounds, it is 
not practical. The setup of the various cameras is cumbersome and potentially 
expensive as duplicate cameras are deployed. Each camera must be calibrated 
accurately relative to the object viewed, and relative to each other. To achieve 
adequate accuracy the stereo cameras would like have to be placed at the top 

30 left and right positions relative to the keyboard. Yet even with this configuration, 
the cameras would be plagued by fingers obstructing fingers within the view of 
at least one of the cameras. Further, the computation required to create three- 
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dimensional information from the two-dimensional video image information output 
by the various cameras contributes to the processing overhead of the computer 
system used to process the image data. Understandably, using multiple 
cameras would substantially complicate Korth's signal processing requirements. 
5 Finally, it can be rather difficult to achieve the necessary camera-to-object 
distance resolution required to detect and recognize fine object movements such 
as a user's fingers while engaged in typing motion. 

In short, it may not be realistic to use a Korth approach to examine two- 
1 0 dimensional luminosity-based video images of a user's hands engaged in typing, 
and accurately determine from the images what finger touched what key (virtual 
or otherwise) at what time. This shortcoming remains even when the acquired 
two-dimensional video information processing is augmented with computerized 
image pattern recognition as suggested by Korth. It is also seen that realistically 
15 Korth's technique does not lend itself to portability. For example, the image 
acquisition system and indeed an ambient light source will essentially be on at 
all times, and will consume sufficient operating power to preclude meaningful 
battery operation. Even if Korth could reduce or power down his frame rate of 
data acquisition to save some power, the Korth system still requires a source of 
20 adequate ambient lighting. 

Power considerations aside, Korth's two-dimensional imaging system does not 
lend itself to portability with small companion devices such as cell phones 
because Korth's video camera (or perhaps cameras) requires a vantage point 
25 above the keyboard. This requirement imposes constraints on the practical size 
of Korth's system, both while the system is operating and while being stored in 
transit. 

What is needed is a method and system by which a user may input data to a 
30 companion computing system using a virtual keyboard or other virtual input 
device that is not electrically connected to the computing system. The data input 
interface emulation implemented by such method and system should provide 
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meaningful three-dimensionally acquired information as to what user's finger 
touched what key (or other symbol) on the virtual input device, in what time 
sequence, preferably without having to use multiple image-acquiring devices. 
Preferably such system should include signal processing such that system output 
5 can be in a scan-code or other format directly useable as input by the companion 
computing system. Finally, such system should be portable, and easy to set up 
and operate 

The present invention provides such a method and system. 

10 

SUMMARY OF THE INVENTION 
The present invention enables a user to input commands and data (collectively, 
referred to as data) from a passive virtual emulation of a manual input device to 
a companion computer system, which may be a PDA, a wireless telephone, or 

15 indeed any electronic system or appliance adapted to receive digital input 
signals. The invention includes a three-dimensional sensor imaging system that 
functions even without ambient light to capture in real-time three-dimensional 
data as to placement of a user's fingers on a substrate bearing or displaying a 
template that is used to emulate an input device such as a keyboard, keypad, or 

20 digitized surface. The substrate preferably is passive and may be a foldable or 
rollable piece of paper or plastic containing printed images of keyboard keys, or 
simply indicia lines demarking where rows and columns for keyboard keys would 
be. The substrate may be defined as lying on a horizontal X-Z plane where the 
Z-axis define template key rows, and the X-axis defines template key columns, 

25 and where the Y-axis denotes vertical height above the substrate. If desired, in 
lieu of a substrate keyboard, the invention can include a projector that uses light 
to project a grid or perhaps an image of a keyboard onto the work surface in front 
of the companion device. The projected pattern would serve as a guide for the 
user in "typing" on this surface. The projection device preferably would be 

30 included in or attachable to the companion device. 
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Alternatively, the subst-ate can be eliminated as a typing guide. Instead the 
screen of the companio ^ computer device may be used to display alphanumeric 
characters as they are ,: typed" by the user on a table top or other work surface 
(perhaps a table top) in front of the companion device. For users who are not 
5 accomplished touch typists, the invention can instead (or in addition) provide a 
display image showing keyboard "keys" as they are "pressed" or "typed upon" by 
the user. "Keys" perceived to be directly below the user's fingers can be 
highlighted in the display in one color, whereas "keys" perceived to be actually 
activated can be highlighted in another color or contrast. This configuration 
10 would permit the user to type on the work surface in front of the companion 
device or perhaps on a virtual keyboard. Preferably as the user types on the 
work surface or the virtual keyboard, the corresponding text appears on a text 
field displayed on the companion device. 

15 Thus, various forms of feedback can be used to guide the user in his or her 
virtual typing. What fingers of the user's hands have "typed" upon what virtual 
key or virtual key position in what time order is determined by the three- 
dimensional sensor system. Preferably the three-dimensional sensor system 
includes a signal processing unit comprising a central processor unit (CPU) and 

20 associated read only memory (ROM) and random access memory (ROM). 
Stored in ROM is a software routine executed by the signal processing unit CPU 
such that three-dimensional positional information is received and converted 
substantially in real-time into key-scan data or other format data directly 
compatible as device input to the companion computer system. Preferably the 

25 three-dimensional sensoremits light of a specific wavelength, and detects return 
energy time-of-flight from various surface regions of the object being scanned, 
e.g., a user's hands. 

At the start of a typing session, the user will put his or her fingers near or on the 
30 work surface or virtual keyboard (if present). Until the user or some other object 
comes within imaging range of the three-dimensional sensor, the present 
invention remains in a standby, low power consuming, mode. In standby mode, 
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the repetition rate of emitted optical pulses is slowed to perhaps 1 to perhaps 10 
pulses per second, to conserve operating power, an important consideration if 
the invention is battery powered. As such, the invention will emit relatively few 
pulses but can still acquire image data, albeit having crude or low Z-axis 
5 resolution. In alternate methods for three-dimensional capture, methods that 
reduce the acquisition frame rate and resolution to conserve power may be used. 
Nonetheless such low resolution information is sufficient to at least alert the 
present invention to the presence of an object within the imaging field of view. 
When an object does enter the imaging field of view, a CPU that governs 

1 0 operation of the present invention commands entry into a normal operating mode 
in which a high pulse rate is employed and system functions are now operated 
at full power. To preserve operating power, when the user's fingers or other 
potentially relevant object is removed from the imaging field of view, the present 
invention will power down, returning to the standby power mode. Such powering 

15 down preferably also occurs when it is deemed that relevant objects have 
remained at rest for an extended period of time exceeding a time threshold. 

Assume that now the user has put his or her fingers on all of the home row keys 
(e.g., A, S, D, F, J, K , L, :) of the virtual keyboard (or if no virtual keyboard is 

20 present, on a work space in front of the companion device with which the 
invention is practiced). The present invention, already in full power mode will now 
preferably initiate a soft key calibration in which the computer assigns locations 
to keyboard keys based upon user input. The user's fingers are placed on 
certain (intended) keys, and based on the exact location of the fingers, the 

25 software assigns locations to the keys on the keyboard based upon the location 
of the user's fingers. 

The three-dimensional sensor system views the user's fingers as the user "types" 
on the keys shown on the substrate template, or as the user types on a work 
30 space in front of the companion device, where "keys" would normally be if a real 
keyboard were present. The sensor system outputs data to the companion 
computer system in a format functionally indistinguishable from data output by 
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a conventional input device such as a keyboard, a mouse, etc. Software 
preferably executable by the signal processing unit CPU (or by the CPU in the 
companion computer system) processes the incoming three-dimensional 
information and recognizes the location of the user's hands and fingers in three- 
5 dimensional space relative to the image of a keyboard on the substrate or work 
surface (if no virtual keyboard is present). 

Preferably the software routine identifies the contours of the user's fingers in 
each frame by examining Z-axis discontinuities. When a finger "types" a key, or 

1 0 "types" in a region of a work surface where a key would be if a keyboard (real or 
virtual) were present, a physical interface between the user's finger and the 
virtual keyboard or work surface is detected. The software routine examines 
preferably optically acquired data to locate such an interface boundary in 
successive frames to compute Y-axis velocity of the finger. (In other 

15 embodiments, lower frequency energy such as ultrasound might instead be 
used.) When such vertical finger motion stops or, depending upon the routine, 
when the finger makes contact with the substrate, the virtual key being pressed 
is identified from the (Z, X) coordinates of the finger in question. An appropriate 
KEYDOWN event command may then be issued. The present invention 

20 performs a similar analysis on all fingers (including thumbs) to precisely 
determine the order in which different keys are contacted (e.g., are "pressed"). 
In this fashion, the software issues appropriate KEYUP, KEYDOWN, and scan 
code data commands to the companion computer system. 

25 The software routine preferably recognizes and corrects for errors in a drifting of 
the user's hands while typing, e.g., a displacement on the virtual keyboard. The 
software routine further provides some hysteresis to reduce error resulting from 
a user resting a finger on a virtual key without actually "pressing" the key. The 
measurement error is further reduced by observing that in a typing application, 

30 the frame rate requirement for tracking Z-values is lower than the frame rate 
requirement for tracking X-values and Y-Values. That is, finger movement in Z- 
direction is typically slower than finger movements in other axes. The present 
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invention also differentiates between impact time among different competing 
fingers on the keyboard or other work surface. Preferably such differentiation is 
accomplished by observing X-axis, Y-axis data values at a sufficiently high frame 
rate, as it is Y-dimension timing that is to be differentiated. Z-axis observations 
5 need not discriminate between different fingers, and hence the frame rate can 
be governed by the speed with which a single finger can move between different 
keys in the Z-dimension. Preferably the software routine provided by the 
invention averages Z-axis acquired data over several frames to reduce noise or 
jitter. While the effective frame rate for Z-values is decreased relative to effective 
1 0 frame rate for X-values and for Y-values, accuracy of Z-values is enhanced and 
a meaningful frame rate of data acquisition is still obtained. 

The software routine can permit the user to toggle the companion computer 
system from say alphanumeric data input mode to graphics mode simply by 
15 "typing" on certain key combinations, perhaps simultaneously pressing the 
Control and Shift In graphics mode, the template would emulate a digitizer table, 
and as the user dragged his or her finger across the template, the (Z, X) locus 
of points being contacted would be used to draw a line, a signature, or other 
graphic that is into the companion computer system. 

20 

Preferably a display associated with the companion computer system can display 
alphanumeric or other data input by the user substantially in real-time. In 
addition to depicting images of keyboard keys and fingers, the companion 
computer system display can provide a block cursorthat shows the alphanumeric 

25 character that is about to be entered. An additional form of input feedback is 
achieved by forming a resilient region under some or all of the keys to provide 
tactile feedback when a "key" is touched by the user's fingers. If a suitable 
companion device were employed, the companion device could even be 
employed to enunciate aloud the names of "typed" keys, letter-by-letter, e.g., 

30 enunciating the letters "c"-"a"-"t" as the word "cat" was typed by a user. A 
simpler form of acoustic feedback is provided by having the companion device 
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emit electronic key-click sounds upon detecting a user's finger depressing a 
virtual key. 

Other features and advantages of the invention will appear from the following 
5 description in which the preferred embodiments have been set forth in detail, in 
conjunction with the accompanying drawings. 

BRIEF DESCRIPTION OF THE DRAWINGS 
FIG. 1A depicts a three-dimensional sensor system used with a passive 
10 substrate keyboard template, according to the present invention; 

FIG. 1 B depicts a three-dimensional sensor system that may be used without a 
substrate keyboard template, according to the present invention; 

15 FIG. 1C depicts a companion device display of a virtual keyboard showing a 
user's finger contacting a virtual key, according to the present invention; 

FIG. 1 D depicts the display of Fig. 1C, showing in additional text entered by the 
user on a virtual keyboard, according to the present invention; 

20 

FIG. 2A depicts a passive substrate in a partially folded disposition, according to 
the present invention; 

FIG. 2B depicts a passive substrate, bearing a different character set, in a 
25 partially rolled-up disposition, according to the present invention; 

FIG. 3 is a block diagram of an exemplary implementation of a three-dimensional 
signal processing and sensor system, with which the present invention may be 
practiced; 

30 

FIG. 4 is a block diagram of an exemplary single pixel detector with an 
associated photon pulse detector and high speed counter as may be used in a 
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three-dimensional sensor system with which the present invention may be 
practiced; 

FIG. 5 depicts contour recognition of a user's fingers, according to the present 
5 invention; 

FIG. 6 depicts use. of staggered key locations in identifying a pressed virtual key, 
according to the present invention; 

10 FIGS. 7A-70 depict cluster matrices generated from optically acquired three- 
dimensional data for use in identifying user finger location, according to the 
present invention. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 
15 Fig. 1A depicts a three-dimensional sensor system 10 comprising a three- 
dimensional sensor 20 focused essentially edge-on towards the fingers 30 of a 
user's hands 40, as the fingers "type" on a substrate 50, shown here atop a desk 
or other work surface 60. Substrate 50 preferably bears a printed or projected 
template 70 comprising lines or indicia representing a data input device, for 
20 example a keyboard. As such, template 70 may have printed images of 
keyboard keys, as shown, but it is understood the keys are electronically passive, 
and are merely representations of real keys. Substrate 50 is defined as lying in 
a Z-X plane in which various points along the X-axis relate to left-to-right column 
locations of keys, various points along the Z-axis relate to front-to-back row 
25 positions of keys, and Y-axis positions relate to vertical distances above the Z-X 
plane. It is understood that (X,Y,Z) locations are a continuum of vector positional 
points, and that various axis positions are definable in substantially more than 
few number of points indicated in Fig. 1 A. 

30 If desired, template 70 may simply contain row lines and column lines demarking 
where keys would be present. Substrate 50 with template 70 printed or 
otherwise appearing thereon is a virtual input device that in the example shown 
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emulates a keyboard. As such substrate 50 and/or template 70 may be referred 
to herein as a virtual keyboard or virtual device for inputting digital data and/or 
commands. An advantage of such a virtual input device is that it may be printed 
on paper or flexible plastic and folded as shown in Fig. 2A, or rolled-up (or folded 
5 and rolled-up) as shown in Fig. 2B. It is understood thatthe arrangement of keys 
need not be in a rectangular matrix as shown for ease of illustration in several of 
the figures, but may be laid out in staggered or offset positions as in a real 
QWERTY keyboard. Fig. 2B also shows the device with an alternate keyset 
printed as template 70, here Cyrillic alphabet characters. If desired, one keyset 
1 0 could be printed on one side of the template, and a second keyset on the other, 
e.g., English and Russian characters. 

As described with respect to Figs. 1B-1D, alternatively an image of a virtual 
keyboard may be displayed on the screen associated with the companion device. 

15 In this embodiment, the substrate and even the work surface can be dispensed 
with, permitting the user to "type" in thin air, if desired. This embodiment is 
especially flexible in permitting on-the-fly changes in the "keyboard" being used, 
e.g., presenting an English language keyboard, or a German language keyboard, 
a Russian language keyboard, to emulate a digitizer sheet, etc. The various 

20 keyboards and keysets are simply displayed on screen 90, associated with 
companion device or appliance 80. Understandably, great flexibility is achieved 
by presenting alternative key sets as displayed images of virtual keys bearing the 
various character sets on the display of the companion device with which the 
present invention is used. Thus, in Fig. 1B, the virtual keyboard has been 

25 eliminated as a guide, further promoting portability and flexibility. 

In the various embodiments, data (and/or commands) to be input by a user from 
a virtual keyboard 50 (as shown in Fig. 1 A), or from a work surface 60 devoid of 
even a virtual keyboard (as shown in Fig. 1B) will be coupled to a companion 
30 computer or other system 80. Without limitation, the companion computer 
system or computer-like system may be a PDA, a wireless telephone, a laptop 
PC, a pen-based computer, or indeed any other electronic system to which is 
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desired to input data. If a virtual keyboard is used, it preferably may be folded 
or rolled when not in use. The folded or rolled size may be made sufficiently 
small to be stored with the PDA or other companion computer system 80, with 
which it will be used to input data and commands. For example, when folded a 
5 keyboard may measure perhaps 2.5" x 3", and preferably at least smaller than 
say 8" x 8". A virtual keyboard for a PDA might have a folded form factor sized 
to fit within a pocket at the rear of the PDA. However when in used, the virtual 
keyboard is unfolded or unrolled to become an essentially full sized albeit virtual 
keyboard. 

10 

As the user inputs data into companion system 80, the display 90 that typically 
is present on system 80 can display in real-time the data being input 100 from 
the virtual keyboard, for example, text that might be input to a PDA, e-mail that 
might be input to a wireless telephone, etc. In one embodiment, a block cursor 

15 102 surrounds a display of the individual alphanumeric character that the 
invention perceives is about to be typed, the letter "d" in Fig. 1 A, for example. 
This visual feedback feature can help a user confirm accuracy of data entry and 
perhaps provide guidance in repositioning the user's fingers to ensure the 
desired character will be typed. Acoustic feedback such as "key clicks" can be 

20 emitted by system 80 as each virtual key is pressed to provide further feedback 
to the user. If desired, passive bumps 1 07 may be formed in the virtual keyboard 
to give the user tactile feedback. By way of example, such bumps may be 
hemispheres formed under each "key" in a virtual keyboard fabricated from a 
resilient plastic, for example. 

25 

As noted, visual feedback may also, or instead, be provided by displaying an 
image of the virtual keyboard (be it a substrate or an empty work surface in front 
of the companion device) on the screen of the companion device. As the user 
types, he or she is guided by an image of a keyboard showing the user's fingers 
30 as they move relative to the virtual keyboard. This image can include highlighting 
the keys directly under the user's fingers, and if a key is actually pressed, such 
key can be highlighted in a different color or contrast. If desired, the screen of 
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the companion device can be "split" such that actual alphanumeric characters 
appear on the top portion of the screen as they are "typed", and an image of 
virtual keys with the user's fingers superimposed appears on the bottom portion 
of the screen (or vice versa). 

5 

In Fig. 1 A and Fig. 1 B, the companion system 80 is shown mounted in an cradle 
1 10, to which the three-dimensional sensor 20 may be permanently attached. 
Alternatively, sensor 20 could be permanently mounted within a preferably lower 
portion of companion device 80. Output from sensor 20 is coupled via path 120 
10 to a data input port 130 on companion device 80. If a cradle or the like is used, 
insertion of device 80 into cradle 110 may be used to automatically make the 
connection between the output of sensor 20 and the input to device 80. 

As described herein, the configuration of Fig. 1 B advantageously permits a user 
15 to input data (e.g., text, graphics, commands) to companion device 80, even 
without a printed virtual keyboard, such as was shown in Fig. 1A. For ease of 
understanding, grid lines along the X-axis and Y-axis are shown on a work 
surface region 60 in front of the companion device 80. Various software mapping 
techniques, described herein , permit the present invention to discern what virtual 
20 keys (if keys were present) the user's fingers intended to strike. Whereas the 
embodiment of Fig. 1A allowed tactile feedback from a virtual keyboard, the 
embodiment of Fig. 1 B does not. Accordingly it is preferred that screen 90 of 
device 80 display imagery to assist the user in typing. Of course, as in the 
embodiment of Fig. 1A, device 80 may emit acoustic key click sounds as the 
25 user's fingers press against surface 60 while "typing". 

Fig. 1 C depicts one sort of visual assistance available from an appropriate device 
80, which assistance may of course be used with the embodiment of Fig. 1 A. In 
Fig. 1 C, screen 90 displays at least part of an image of a keyboard 1 1 5 and an 
30 outline or other representation 40" of the user's hands, showing hand and finger 
location relative to where keys would be on an actual or a virtual keyboard. For 
ease of illustration, Fig. 1C depicts only the location of the user's left hand. As 
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a key is "touched" or the user's finger is sufficiently close to "touching" a key 
(e.g., location on surface 60 at which such key would be present if a keyboard 
were present), device 80 can highlight the image of that key (e.g., display the 
relevant "softkey"), and as the key is "pressed" or "typed upon", device 80 can 
5 highlight the key using a different color or contrast. For example in Fig. 1 C, the 
"Y" key is shown highlighted or contrasted, which can indicate it is being touched 
or is about to be touched, or it is being pressed by the user's left forefinger. As 
shown in Fig. 1D, a split screen display can be provided by device 80 in which 
part of the screen depicts imagery to guide the user's finger placement on a non- 

1 0 existent keyboard, whereas another part of the screen shows data or commands 
100 input by the user to device 80. Although Fig. 1D shows text that 
corresponds to what is being typed, e.g., the letter "Y" in the word "key" is 
highlighted as spelling of the word "key" on screen 90 is completed, data 100 
could instead be a graphic. For example, the user can command device 80 to 

1 5 enter a graphics mode whereupon finger movement across surface 60 (or acro%^ 
a virtual keyboard 70) will produce a graphic, for example, the user's signature 
"written" with a forefinger or a stylus on surface 60. Collectively, user finger(s) 
or a stylus may be referred to as a "user digit". 



Optionally software associated with the invention (e.g., software 285 in Fig. 3) 
can use word context to help reduce "typing" error. Assume the vocabulary of 
the text in a language being input is known in advance, English for example. 
Memory in the companion device will store a* dictionary containing most 
frequently used words in the language and as the user "types" a word on a virtual 
keyboard or indeed in thin air, the companion device software will match letters 
thus far typed with candidate words from the dictionary. For instance, if the user 
enters "S", all words starting with letter "S" are candidates; if the user enters 
"SU", all words starting with "SU" are candidates. If the user types '"SZ" then, at 



Jeast in English, there will be no matching candidate w ord(s)j As the user types 
50 more letters, the set of candidate words that can match the word being typed 
reduces t^^Jiiaiia^ge^bJa^izeA At some threshold point, for insE 
size of the~ca?io^dBte-wefdsHreduces to 5-10 words, the software can assign a 
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probability to the next letter to be typed by the user. For instance, if the user has 
entered "SUBJ", there is a higher probability that the next letter is the letter "E", 
rather than say the letter "W". But since letters "E" and "W" are neighbors on a 
real or virtual keyboard, it is possible that the user might press the region near 
!> the key for the letter "W". In this example, companion device software can be 
used to^co7rec£*he key entry and to assume that the user meant to enter the 




Turning now to operation of three-dimensional sensor 20, the sensor emits 
10 radiation of a known frequency and detects energy returned by surfaces of 
objects within the optical field of view. Emitted radiation is shown in Figs. 1 A and 
1 B as rays 140. Sensor 20 is aimed along the Z-axis to determine which of the 
user's finger tips 30 touch what portions of template 70, e.g., touch which virtual 
keys, in what time order. As shown in Fig. 1 B, even if template 70 were absent 
15 and the user simply typed on the work space in front of device 80, sensor 20 
would still function to output meaningful data. In such an embodiment, screen 
90 of companion device 80 could display an image 100' of a keyboard 105 in 
which "pressed" or underlying "keys" are highlighted, such as key 107, for the 



As shown in Figs. 1A and 1B, if desired a light or other projector 145 that emits 
visual light beams 147 could be used to project an image of a virtual keyboard 
to guide the user in typing. For example, a source of visible light (perhaps laser 
light in a visible wavelength) may be used with diffraction type lenses to project 

25 an image to guide the user in typing. In such embodiments, the image of a 
keyboard, perhaps rendered in a common graphics file format (e.g., GIF) is used 
to "etch" a diffractive pattern on the lens. Although portions of the projected 
image would at times fall on the surface of the user's fingers, nonetheless in the 
absence of a substrate to type upon, such a projected guide can be useful. The 

30 use of diffractive optics including such optics as are commercially available from 
MEMS Optical, LLC of Huntsville, AL 35806 may find application in implementing 
such a projection embodiment. 




letter "E". 



letter "T". 
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Fig. 3 is a block diagram depicting an exemplary three-dimensional image sensor 
system 200 that preferably is fabricated on a single CMOS IC 210. System 200 
may be disposed in the same housing as three-dimensional sensor 20, and is 
used to implement the present invention. As described in greater detail in co- 
5 pending U.S. application serial number 09/401,059, incorporated herein by 
reference, such a system advantageously requires no moving parts and relatively 
few off-chip components, primarily an light emitting diode (LED) or laser source 
220 and associated optical focusing system, and if suitable shielding were 
provided, one might bond laser source 220 onto the common substrate upon 
1 0 which IG 21 0 is fabricated. It is to be understood that while the present invention 
is described with respect to a three-dimensional sensor 20 as disclosed in the 
above-referenced co-pending U.S. utility patent application, the invention may be 
practiced with other three-dimensional sensors. 

1 5 System 200 includes an array 230 of pixel detectors 240, each of which has 
ded icated circuitry 250 for processing detection charge output by the associated 
detector. In a virtual keyboard recognition application, array 230 might include 
15x100 pixels and a corresponding 15x100 processing circuits 250. Note that 
the array size is substantially less than required by prior art two-dimensional 

20 video systems such as described by Korth. Whereas Korth requires a 4:3 aspect 
ratio or perhaps in some cases 2:1 , the present invention obtains and processes 
data using an aspect ratio substantially less than 3:1 , and preferably about 2:15 
or even 1:15. Referring to Figs. 1A and 1B, it is appreciated that while a 
relatively large X-axis range must be encompassed, the edge-on disposition of 

25 sensor 20 to substrate 50 means that only a relatively small Y-axis distance need 
be encompassed. 

During usertyping, a high frame rate is required to distinguish between the user's 
various fingers along a row of virtual keys. However, the back and forth 
30 movement of a given typing finger is less rapid in practice. Accordingly the rate 
of acquisition of Z-axis data may be less than X-axis and Y-axis date, for 




WO 01/59975 



PCT/US01/40090 



example 1 0 frames/second for Z-axis data, and 30 frames/second for X-axis and 
for Y-axis data. 

A practical advantage of a decreased Z-axis frame rate is that less electrical 
5 current is required by the present invention in obtaining keyboard finger position 
information. Indeed, in signal processing acquired information, the present 
invention can average Z-axis information over frames, for example examining 
one-third of the frames for Z-axis position information. Acquired Z-axis values 
will have noise or jitter that can be reduced by averaging. For example Z-values 

10 may be averaged over three successive thirty frame/second frames such that 
three consecutive image frames will share the same processed Z-values. While 
the effective frame rate for Z-values is lowered to one-third the acquisition rate 
for X-axis and Y-axis data acquisition, accuracy of the Z data is improved by 
averaging out the noise or jitter. The resultant decreased Z-axis frame rate is still 

1 5 sufficiently rapid to acquire meaningful information. This use of different frame 
rates for X-values and Y-values, versus Z-values is useful to the present 
invention. For example, a reduced acquisition rate of Z-axis data relative to X- 
axis and Y-axis data minimizes electrical current drain, and avoids taxing the 
signal processor (CPU 260) with redundant signal processing. 

20 

Thus, the present invention acquires three-dimensional image data without 
requiring ambient light, whereas prior art Korth-like systems acquire two- 
dimensional luminosity data in the presence of ambient light. In essence, the 
present invention can sense three-dimensionaily objects, e.g., fingers and 
25 substrate, analogously to a human's feeling an object by touching. 
Advantageously, this can be accomplished using relatively small operating 
power, e.g., perhaps 3.3 VDC at 10 mW, which permits the present invention to 
be battery operated and fabricated in a relatively small and mobile form factor. 

30 Multiple frames per second of three-dimensional image data of the user's hands 
and fingers and the substrate are available from array 230. Using this data the 
present invention constructs a three-dimensional image of the hands and frngers 
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relative to the substrate, or if the substrate is absent, relative to where virtual 
keys would be if a keyboard were on the work surface in front of the companion 
device 80. Exemplary techniques for doing so are described in applicant Bamji's 
earlier referenced co-pending U.S. patent application. Constructing such a three- 
5 dimensional image from time-of-f light data is superior to prior art methods that 
attempt to guess at spatial relationships using two-dimensional luminosity based 
data, e.g., as suggested by Korth. It should be noted that time of flight methods 
may include return pulse time measurement, phase or frequency detection, or 
a high speed shutter method, as described in the Bamji patent application. Other 
10 methods that do not rely on time-of-f light can capture three-dimensional data, 
including stereo imagery, and luminosity-based techniques that discern depth 
from reflective intensity. 

In practice, array 230 can acquire and generate data at 30 frames/second, a 
15 frame rate sufficient to process virtual typing of 5 characters/second, which is 
about 60 words/minute. If array 230 is rectangular, e.g., comprising a number 
n of X-axis pixels and a number m Y-axis pixels, if n=100 and m =15, then a grid 
comprising 1 ,500 pixels is formed. For each frame of data, each pixel in array 
230 will have a value representing the vector distance from sensor 20 to the 
20 surface of the object (e.g., a portion of a user's finger, a portion of the substrate, 
etc.) captured by that pixel, e.g. , a vector or Z-value. This data is far more useful 
than Korth's luminosity-based image data that at best provided video frames with 
RGB grey or color scale values in determining the contour of a user's fingers and 
location on a virtual keyboard, in two dimensions. 

25 

Use of acquired three-dimensional data permits software 285 to determine the 
actual shape of the user's fingers (nominally assumed to be somewhat 
cylindrical), and thus relative finger position with respect to other fingers, to 
location over or on the substrate, and relative to three-dimensional sensor 20. 
30 In Fig. 1 A, for example, as a finger is sensed to be moving to a Y=0 position, it 
can be determined that the finger is probably preparing to type a virtual key. If 
that finger is also sensed to be approaching the Z=Z1 region, then that finger is 
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probably prepared to type a virtual key in the first row of keys on the virtual 
keyboard. Determination of whether a virtual key is about to be pressed also 
takes into account velocity data. For example, a user finger detected to be 
moving rapidly downward toward Y=0 is probably getting ready to strike a virtual 
5 key. 

In Fig. 3, IC 210 will also include a microprocessor or microcontroller unit 260 
(denoted CPU), random access memory 270 (RAM) and read-only memory 280 
(ROM), a portion of which ROM preferably holds a software routine 285 

1 0 executable by the CPU to implement the present invention. Controller unit 260 
preferably is a 16-bit RISC microprocessor operating at perhaps 50 MHz. 
Among other functions, CPU 260 performs vector distance to object and object 
velocity calculations, where the object is the substrate and user's hands. IC 2 1 0 
further includes a high speed distributable clock 290, and various computing, 

15 optical drive input/output (I/O) circuitry 300, and interface data/command 
input/output (I/O) circuitry 310. Digital keyboard scan type data or digitizer 
tablet/mouse type data is output from I/O 310, for example from COM and/or 
USB type ports associated with system 200. 

20 Preferably the two-dimensional array 230 of pixel sensing detectors is fabricated 
using standard commercial silicon technology, which advantageously permits 
fabricating circuits 250, 260, 270, 280, 290, and 300 on the same IC 210. 
Understandably, the ability to fabricate such circuits on the same IC with the 
array of pixel detectors can shorten processing and delay times, due to shorter 

25 signal paths. 

Each pixel detector may be represented as a parallel combination of a current 
source, an ideal diode, and shunt impedance and noise current source. Each 
pixel detector will output a current proportional to the amount of incoming photon 
30 light energy falling upon it. Preferably CMOS fabrication is used to implement 
the array of CMOS pixel diodes or photogate detector devices. For example 
photodiodes may be fabricated using a diffusion-to-well, or a well-to-substrate 
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junction. Well-to-substrate photodiodes are more sensitive to infrared (IR) light, 
exhibit less capacitance, and are thus preferred. 

As shown in Figs. 3 and 4, a circuit 250 is associated with each pixel detector 
5 240. Each circuit 250 preferably includes a pulse peak detector 310, a high 
speed counter 320, and has access to the high speed clock 290. Preferably 
formed on IC 210, high speed clock 200 outputs a continuous train of high 
frequency clock pulses preferably at a fixed frequency of perhaps 500 MHz, 
preferably with a low duty cycle as the pulses are output. Of course, other high 

1 0 speed clock parameters could instead be used. This pulse train is coupled to the 
input port of each high speed interpolating counter 320. Counter 320 preferably 
can sub-count, as described in the Bamji pending patent application, and can 
resolve times on the order of 70 ps. Preferably each counter 320 also has a port 
to receive a START signal (e.g., start now to count), a port to receive a STOP 

15 signal (e.g., stop counting now), and a port to receive a CONTROL signal (e.g., 
reset accumulated count now). The CONTROL and START signals are available 
from controller 260, the CLOCK signal is available from clock unit 290, and the 
STOP signal is available from pulse peak detector 310. 

20 Virtual keyboard 50 will be placed perhaps 20 cm distant from three-dimensional 
sensor 20, substantially in the same plane as the sensor lens. Since a typical 
sensor lens angle is perhaps 60°, a 20 cm distance ensures optical coverage of 
the virtual keyboard. In Fig. 3, for ease of illustration the distance between 
sensor 20 light emissions and collected light has been exaggerated. 

25 

In overview, system 200 operates as follows. At time to, microprocessor 260 
commands light source 220 to emit a pulse of light of known wavelength, which 
passes through focus lens 288' and travels at the speed of light (C), 300,000 
km/sec. toward objects of interest, e.g., substrate 50 and user's fingers 30. If 
30 light source 220 is sufficiently powerful, lens 288' may be dispensed with. At the 
surface of the object being imaged at least some of the light may be reflected 
back toward system 200 to be sensed by the detector array. In Fig. 3, the 
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objects of interest are the fingers 30 of a user's hand, and, if present, substrate 
50, which as noted ma / include viewable indicia such as keyboard keys 70 or 
perhaps projected grid lines, to guide the user in finger placement while "typing". 

5 As was indicated by Fig. 1A, the position of virtual keys 70 (or other user 
available indicia) on substrate 50 is known in two dimensions on the X-Z plane 
relative to the position of other such keys on the substrate. As the user's fingers 
move back and forth over substrate 50, touching virtual keys 70 while "typing", 
it is a function of CPU 260 and software routine 285 to examine return optical 
10 energy to identify which, if any, virtual keys are being touched by the user's 
fingers at what times. Once this information is obtained, appropriate KEYUP, 
KEYDOWN, and key scan code or other output signals may be provided to input 
port 1 30 of the companion device 80, just as though the data or commands being 
provided were generated by an actual keyboard or other input device. 

15 

At or before time to, each pixel counter 310 in array 230 receives a CONTROL 
signal from controller 260, which resets any count previously held in the counter. 
At time t0, controller 260 issues a START command to each counter, whereupon 
each counter begins to count and accumulate CLOCK pulses from clock 290. 
20 During the roundtrip time of flight (TOF) of a light pulse, each counter 
accumulates CLOCK pulses, with a larger number of accumulated clock pulses 
representing longer TOF, which is to say, greater distance between a light 
reflecting point on the imaged object and system 200. 

25 The fundamental nature of focus lens 288 associated with system 200 is such 
that reflected light from a point on the surface of imaged object 20 will only fall 
upon the pixel in the array focused upon such point. Thus, at time t1, photon 
light energy reflected from the closest point on the surface of object 20 will pass 
through a lens/filter 288 and will fall upon the pixel detector 240 in array 230 

30 focused upon that point. A filter associated with lens 288 ensures that only 
incoming light have the wavelength emitted by light source 220 falls upon the 
detector array unattenuated. 
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Assume that one particular pixel detector 240 within array 230 is focused upon 
a nearest surface point on the tip 70 of the nearest user's finger. The associated 
detector 300 will detect voltage that is output by the pixel detector in response 
to the incoming photon energy from such object point. Preferably pulse detector 
5 300 is implemented as an amplifying peak detector that senses a small but rapid 
change in pixel output current or voltage. When the rapidly changing output 
voltage is sufficiently large to be detected, logic within detector 300 (e.g., an SR 
flipflop) toggles to latch the output pulse, which is provided as the STOP signal 
to the associated counter 320. Thus, the number of counts accumulated within 
10 the associated counter 320 will be indicative of roundtrip TOF to the near portion 
of the fingertip in question, a calculable distance Z1 away. 

Distance Z1 may be determined from the following relationship in which C is the 
velocity of light: 

15 Z1 = O(t1-t0)/2 

At some later time t2 photon energy will arrive at lens 288 from a somewhat more 
distant portion of the user's fingertip, 30, and will fall upon array 230 and be 
detected by another pixel detector. Hitherto the counter associated with this 
other detector has continued to count CLOCK pulses starting from time to, as 

20 indeed have all counters except for the counter that stopped counting at time t1 . 
At time t2, the pulse detector associated with the pixel just now receiving and 
detecting incoming photon energy will issue a STOP command to the associated 
counter. The accumulated count in this counter will reflect roundtrip TOF to the 
intermediate point on the fingertip, a distance Z2 away. Within IC 21 0, controller 

25 260 executing software routine 285 stored in memory 280 can calculate distance 
associated with the TOF data for each light reflecting point on the object surface. 
Velocity can be calculated by examining successive frames of acquired data. 

In similar fashion, at time t3 yet another pixel detector in the array will detect 
30 sufficient just-arriving photon energy for its associated pulse detector 300 to 
issue a STOP command to the associated counter. The accumulated count in 
this counter represents TOF data for a still farther distance Z3 to the imaged 



2 Y 



WO 01/59975 



PCTYUS01/40090 



object. Although for ease of illustration Fig. 3 shows but three emitted light rays 
and light reflections, all falling near one fingertip, in practice substantially all of 
the substrate and user's fingers and thumbs will be subjected to illumination from 
light source 220, and will reflect at least some energy into lens 288 associated 
5 with three-dimensional sensor 20. 

Some pixels in the array may of course not receive sufficient reflected light from 
the object point upon which they are focused. Thus, after a predetermined 
amount of time (that may be programmed into controller 260), the counter 
10 associated with each pixel in the sensor array will have been stopped due to 
pulse detection (or will be assumed to hold a count corresponding to a target at 
distance Z = infinity). 

As noted, in the present application it suffices if system 200 can accurately image 
15 objects within a range of perhaps 20 cm to 30 cm, e.g., about 20 cm plus the 
distance separating the top and the bottom "row" of virtual keys on substrate 50. 
With each detected reflected light pulse, the counter-calculated TOF distance 
value for each pixel in the array is determined and preferably stored in a frame 
buffer in RAM associated with unit 270. Preferably microprocessor 260 
20 examines consecutive frames stored in RAM to identify objects and object 
location in the field of view. Microprocessor 260 can then compute object, e.g., 
finger movement velocity. In addition to calculating distance and velocity, the 
microprocessor and associated on-chip circuitry preferably are programmed to 
recognize the outline or contours of the user's fingers, and to distinguish the 
25 finger surfaces from the substrate surface. Once the finger contours are 
identified, system 200 can output via a COM or USB or other port relevant digital 
data and commands to the companion computer system. 

The above example described how three pixel detectors receiving photon 
30 energies at three separate times t1 , t2, t3 turn-off associated counters whose 
accumulated counts could be used to calculate distances Z1, Z2, Z3 to finger 
surfaces and the substrate in the field of view. In practice, the present invention 
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will process not three but thousands or tens of thousands of such calculations 
per each light pulse, depending upon the size of the array. Such processing can 
occur on 1C chip 210, for example using microprocessor 260 to execute routine 
285 stored (or storable) in ROM 280. Each of the pixel detectors in the array will 
5 have unique position locations on the detection array, and the count output from 
the high speed counter associated with each pixel detector can be uniquely 
identified. Thus, TOF data gathered by two-dimensional detection array 230 may 
be signal processed to provide accurate distances to three-dimensional object 
surfaces, such as a user's fingers and a substrate. It will be appreciated that 
10 output from CMOS-compatible detectors 240 may be accessed in a random 
manner if desired, which permits outputting TOF DATA in any order. 

Light source 220 is preferably an LED or a laser that emits energy with a 
. wavelength of perhaps 800 nm, although other wavelengths could instead be 
1 5 used. Below 800 nm wavelength, emitted light starts to become visible and laser 
efficiency is reduced. Above 900 nm CMOS sensor efficiency drops off rapidly, 
and in any event, 1 100 nm is the upper wavelength for a device fabricated on a 
silicon substrate, such as IC 210. As noted, by emitted light pulses having a 
specific wavelength, and by filtering out incoming light of different wavelength, 
20 system 200 is operable with or without ambient light. If substrate 50 contained, 
for example, raised ridges defining the outlines of virtual keys, a user can literally 
type in the dark and system 200 would still function properly. This ability to 
function without dependence upon ambient light is in stark contrast to prior art 
schemes such as described by Korth. As noted, even for users who are not 
25 accomplished touch typists, the present invention may be used in the dark by 
providing an image of a virtual keyboard on the display of companion device 80. 

As noted, lens 288 preferably focuses filtered incoming light energy onto sensor 
array 230 such that each pixel in the array receives light from only one particular 
30 point (e.g., an object surface point) in the field of view. The properties of light 
wave propagation allow an ordinary lens 288 to be used to focus the light onto 
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the sensor array. If a iens is required to focus the emitted light, a single lens 
could be used for 288, 288' if a mirror-type arrangement were used. 

In practical applications, sensor array 230 preferably has sufficient resolution to 
5 differentiate target distances on the order of about 1 cm, which implies each pixel 
must be able to resolve time differences on the order of about 70 ps (e.g., 1 
cm/C). In terms of a CMOS-implemented system specification, high speed 
counters 320 must be able to resolve time to within about 70 ps, and peak pulse 
detectors 310 must be low-noise high speed units also able to resolve about 70 
10 ps (after averaging about 100 samples) with a detection sensitivity on the order 
of perhaps a few hundred microvolts (|JV). Accurate distance measurements will 
require that the pulse detector response time be removed from the total elapsed 
time. Finally, the CLOCK signal output by circuit 280 should have a period on 
the order of about 2 ns. 

15 

As noted above, each interpolating counter 320 preferably can resolve distances 
on the order of 1 cm, which implies resolving time to the order of about 70 ps. 
Using a 1 0-bit counter with an effective 70 ps cycle time would yield a maximum 
system detection distance of about 10 m (e.g., 1,024 cm). Implementing an 

20 ordinary 10-bit counter would typically require a worst case path of perhaps 40 
gates, each of which would require typically 200 ps, for a total propagation time 
of perhaps about 8 ns. This in turn would limit the fastest system clock cycle 
time to about 10 ns. Using carry look-ahead hardware might, at a cost, reduce 
counter propagation time, but nonetheless a 2 ns system cycle time would be 

25 quite difficult to implement. 

To achieve the required cycle time, a so-called pseudo random sequence 
counter (PRSC), sometimes termed a linear shift register (LSR), may be used. 
Details for implementing high speed counters including PRSC units may be 
30 found in applicant's earlier-referenced co-pending utility patent application. 
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Considerations involved in recognizing contour of the user's fingers within the 
optical field of view will now be described with reference to Fig. 5, which depicts 
a cross-section of two of the user's fingers. The + symbols show sub-frame 
(intra-frame) samples of vector distance values for each pixel sensor in array 21 0 
5 imaging the fingers. Inherent noise associated with the pixel sensors produces 
varying vector distances to the same point of the imaged finger object in each 
acquired sample. TO reduce noise and improve signal/noise, the sensor 
averages out measurements for each pixel to produce average values for the 
frame, shown by the O symbol in Fig. 5. The □ symbol in Fig. 5 represents the 
10 corrected average when a template, or set of stored exemplary finger-shaped 
cross-sections, is used by routine 285 to interpret the average values. This 
method enhances distance measurement accuracy, and reduces ambiguity in 
recognizing the user's fingers. 

1 5 Data capture noise can affect the minimum frame rate needed to recognize the 
user's fingers and determine finger motion and velocity. In TOF-based imagery, 
as used in the present invention, pixel-level noise manifests itself as variations 
in distance values for a given pixel, from one frame to another frame, even if the 
imaged object remains stationary. 

20 

For ease of illustration, the keyboard images depicted in Figs. 1A and 2A, 2B 
were drawn as a matrix, e.g., uniform rows and columns. But in practice, as 
shown partially in Fig. 6, standard QWERTY-type keyboards (and indeed 
keyboards with other key configurations) are laid out in an offset or staggered 

25 configuration. The present invention advantageously reduces the requirement 
for Z-axis resolution by taking into account the staggering of actual keyboard 
layouts. Thus, the second row from the top of a keyboard is shifted slightly to the 
right, and the third row (from the top) is shifted further to the right, and so on. 
This staggering places the keys in each row at an offset position with respect to 

30 the keys in the adjacent row. By way of example, note the keyboard letter "G" 
in Fig. 6. Dotted rectangle 400 indicates allowable latitude given a user in 
striking the letter "G", e.g., any virtual contact within the rectangle area will 
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unambiguously be interpreted as user finger contact on the letter "G". The height 
of this rectangle, denoted by Z is the maximum error margin allowed in detecting 
a Z-axis coordinate. Note that this margin is greater than the height of a single 
row R in a QWERTY keyboard. It is also noted that the region of recognition for 
5 a key need not be rectangular, and may be of any reasonable shape, for 
example, an ellipse centered at the key. 

As acquired frames of three-dimensional data become available to CPU 270 and 
to routine 285, recognition of the user's fingers from the acquired data proceeds. 

10 This task is simplified in that the data indeed includes a three-dimensional 
representation of the user's fingers, and the fingers will have a reasonably well 
known shape, e.g., when viewed edge-on, they are somewhat cylindrical in 
shape. As noted, storing exemplary templates of finger shapes and finger and 
hand heuristics in memory 280 expedites finger recognition by reducing CPU 

1 5 time needed to recognize and track finger positions. Such signal processing can 
quickly reduce data capture noise and more readily discern the user's fingers 
from among the three-dimensional data acquired. Signal to noise ratio can also 
be improved in intra-frame states in that knowledge of the scene being imaged 
is known, e.g., the scene comprises a virtual keyboard and user's hands. 

20 Preferably a few hundred data captures are averaged or otherwise used to 
construct a frame of acquired data. 

Once the user's fingers are recognized, software routine 285 (or an equivalent 
routine, perhaps executed by other than CPU 260, can next determine position 

25 and motion (e.g., relative change of position per unit time) of the fingers. Since 
data representing the fingers are in three dimensions, routine 285 can readily 
eliminate background images and focus only on the user hands. In a Korth two- 
dimensional imaging scheme, this task is very difficult as the shape and 
movement of background objects (e.g., a user's sleeve, arm, body, chair contour, 

30 etc.) can confuse object tracking and recognition software routines. 
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Using contour of the finger tips, routine 285 usesZ-axis distance measurements 
to determine position of the fingers with respect to the rows of the virtual 
keyboard, e.g., distance Z1 or Z2 in Fig. 1A. As noted, the granularity of such 
axis measurements is substantially greater than what is depicted in Fig. 1 A. X- 
5 axis distance measurements provide data as to fingertip position with respect to 
the columns of the virtual keyboard. Using row and column co-ordinate numbers, 
software 285 can determine the actual virtual key touched by each finger, e.g., 
key "T" by the left forefinger in Fig. 1 A. 

1 0 To help the user orient the fingers on a particular virtual input device such as a 
keyboard, numeric pad, telephone pad, etc., software within the companion 
device 80 can be used to display a soft keyboard on a screen 90 associated with 
the device (e.g., a PDA or cellular telephone screen), or on a display terminal 
coupled to device 80. The soft keyboard image will show user finger positions 

1 5 for all keys on (or close to) virtual keyboard 50, for example by highlighting keys 
directly under the user's fingers. When a key is actually struck (as perceived by 
the user's finger movement), the struck key may be highlighted using a different 
color or contrast. If the virtual keys are not in a correct rest position, the user can 
command the companion device to position the virtual keyboard or other input 

20 device in the proper starting position. For instance, if the user typically begins 
to key by placing the right hand fingers on home row J, K, L, and ":" keys, and 
the left fingers on F, D, S and A keys, the software will move the keys of the 
virtual keyboard to such a position. 

25 Vertical Y-axis motion of the user's fingers is sensed to determine what virtual 
keys on device 50 are being typed upon, or struck. While typing on a mechanical 
keyboard several fingers may be in motion simultaneously, but normally only one 
finger strikes a key, absent double key entries such pressing the CONTROL key 
and perhaps the "P" key, or absent a typographical error. In the present 

30 invention, software routine 285 determines finger motion information from 
successive frames of acquired information. Advantageously, the human hand 
imposes certain restrictions upon finger motion, which restrictions are adopted 
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in modeling an imago of the user's hands and fingers. For example, a 
connectiveness property of the fingers imposes certain coupling between 
movement of the fingers. The degree of freedom at the finger joints gives certain 
freedom to each fingerto move, for example to move nearer or further from other 
5 fingers. Routine 285 advantageously can employ several heuristics to determine 
what virtual key is actually being struck. For instance, a keystroke can be 
sensed as commencing with a detected finger up movement followed by a quick 
finger down motion. A user's finger having the smallest Y-axis position or the 
greatest downward velocity is selected as the key entry finger, e.g., the finger 
1 0 that will strike one of the virtual keys on the virtual data input device. 

Unintended key entry by a user is discerned by intelligently monitoring movement 
of the user's fingers. For example, the user may rest the fingers on a surface of 
substrate 50 without triggering unintended key entries. This is analogous to a 

1 5 condition where a typist using a mechanical keyboard rests his or her fingers on 
the keys without pressing any key sufficiently hard to type. A user of the present 
invention is also permitted to move his or her fingers gently over the virtual 
keyboard without unintentional triggering any key. Software 285 can calibrate its 
operation such that only intentional gestures are admitted as valid key entry to 

20 input data or commands to the companion computer device 80. 

Software 285 upon execution by a CPU such as CPU 270 may be used to 
implement an algorithm or routine to recognize what virtual keys are being typed 
upon by a user of the present invention. Input data for the algorithm is three- 

25 dimensional optical information obtained from sensor 20. An exemplary 
algorithm may be considered as having three phases: building and personalizing 
templates, calibration, and actually tracking user typing on a virtual keyboard or 
work surface. In the description that follows it will be assumed that normal typing 
is undertaken in which all fingers are used. For instances where one or two 

30 fingers only are used, a special case of the algorithm will apply. 
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Templates are understood to be predefined models of different typing posture for 
different users. This class of templates is based upon analysis of a population 
of system users, whose various typing styles will have been classified. It is to be 
noted that the templates may be derived from examples of input data (e.g 
5 examples of data collected by observing fingers in typing position) or from a 
preprogrammed mathematical description of the geometrical properties of the 
objects to be tracked (e.g. a cylindrical description for fingers). The resultant 
templates may be created at the time ROM 280 and especially routine 285 is 
fabricated. Since the position and shape of keyboard keys imposes certain 
10 commonalities of style upon users, it will be appreciated that the number of 
predefined templates need not be excessively large. 

Preferably individual users of the present invention can also construct their own 
dedicated templates using a training tool that guides the user through the steps 

1 5 needed to build a template. For instance, a training program portion of software 
285 can present on display 90 commands telling the user to place his or her 
fingers in typing position on the virtual keyboard, if present, or the work surface 
in front of the companion device 80. The training program will then tell the user 
to repeatedly press a virtual key under each finger. Optically capturing thumb 

20 movement can be treated as a special case since thumb movement differs from 
finger movement and typically is restricted to repressing the space bar region of 
a virtual keyboard or work surface. 

In building the template, it is desired to construct a classification of the objects 
25 in the template image as being the different fingers of the user's hands. As 
described in further detail following, this method step collects information for the 
classifier or algorithm routine as to the physical properties of the user's hand. 
Later, during actual typing, the classifier uses this template to quickly map image 
in acquired frames to each user's fingers. As part of the template construction, 
30 preferably a mapping of the positions of the user's fingers to specific keyboard 
keys at a rest position is defined. For instance, routine 285 and CPU 270 can 
instruct the companion device 80 that, at rest, the user's left hand fingers touch 
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the :"A", "S", "D" and "F" keys, and the user's right hand fingers touch the "J", "K", 
"L", and ":" keys. Such method step personalizes the virtual keyboard to the style 
of a particular user. This personalization process is carried out once and need 
not be repeated unless the user's typing posture changes substantially to where 
5 too many wrong keys are being identified as having been typed upon. A 
calibration process according to the present invention may be carried out as 
follows. At the start of a typing session, the user will so signal the companion 
device 80 by putting the application being run by device 80 in a text input mode. 
For example, if device 80 is a PDA, the user can touch a text field displayed on 
1 0 screen 80 with a stylus or finger, thereby setting the input focus of the companion 
80 application to a text field. Other companion devices may be set to the 
appropriate text input mode using procedures associated with such devices. 

Next the user's fingers are placed in a typing position in the work surface in front 
15 of three-dimensional sensor 20, either on a virtual keyboard or simply on the 
work surface. This step is used to map the user fingers to the elements of the 
template and to calibrate the user's fingers to the keys of the virtual keyboard (or 
work surface) before a typing session starts. 

20 At this juncture, three-dimensional sensor 20 will be repeatedly capturing the 
contour map of the user's fingers. The data thus captured will be placed, e.g., 
by software 285 in a table or matrix such as shown in Figs. 7A-70. 

Fig. 7A depicts a user's left hand typing on an actual keyboard, as imaged by 
25 sensor 20. The field of view (FOV) of sensor 20 is intentionally directed toward 
the upper work surface, which in this example was an actual keyboard. Five 
fingers of the left hand are shown, and may be identified as fingers 1 (thumb), 2, 
3, 4, and 5 (little finger). The cross-hatched region behind and between the 
fingers indicates regions too dark to be considered part of the user's fingers by 
30 the present invention. In an actual setting, there would of course be varying 
degrees of darkness, rather than the uniform dark region shown here for ease 
of understanding, and of depiction. 
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, An overlay grid-like matrix or table is shown in Fig. 7A, in which various regions 
have quantized digits representing a normalized vector distance between the 
relevant surface portion of a user's finger and sensor 20. It is understood that 
these quantized distance values are dynamically calculated by the present 
5 invention, for example by software 285. In the mapping shown in Fig. 7A, low 
digit values such as 1, 2, represent close distances, and higher values such as 
7, 8 represent large distances. The "d" values represent perceived 
discontinuities. Depending on the technology associated with sensor 20, values 
of "d" may oscillate widely and can indicate the absence of a foreground object. 
10 In Fig. 7A, the quantized distance values indicate that the user's left thumb is 
farther away from sensor 20 (as indicated by relatively high distance values of 
7 and 8) than is the user's left forefinger, whose distance values are relatively 
low, e.g., 1. It is also seen that the user's left little finger is in generally more 
distance from sensor 20 than is the user's forefinger. 

15 

The central portion of Fig. 7A is a table or matrix showing the normalized 
distance values and, where applicable, "d" entries. A similar table is also shown 
in Figs. 7B-70. The table entries can represent contours of user fingers, and 
shading has been added to these tables to assist in showing potential mapping 

20 of distance data to an outline of the user's fingers. Arrows from the FOV portion 
of Fig. 7A pointing to columns in the table indicate how various columns of data 
can indeed represent contours of user finger position. In the tables shown in 
Figs. 7A-70, circled numbers "1", "2" ... "5" depict contours corresponding to 
perceived location of the users left thumb (finger "1"), forefinger, middle finger, 

25 ring finger, and little finger (finger "5") respectively. 

As described earlier, templates preferably are used in the present invention to 
help identify userfinger positions from data obtained from sensor 20. Templates 
can assist classification algorithm (or classifier) 285 in distinguishing boundaries 
30 between fingers when discontinuities are not necessarily apparent. For example, 
in Fig. 7A, the third and fourth user's fingers (fingers 3 and 4) are relatively close 
together. 
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Shown at the bottom o : Fig. 7 A is a dynamic display of what the user is typing, 
based upon analysis by the present invention of the sensor-perceived distance 
values, dynamic velocity values, as well as heuristics associated with the overall 
task of recognizing what keys (real or virtual) are being pressed at what time. 
5 Thus, at the moment captured in Fig. 7A, the user's left forefinger (finger 2) 
appears to have just typed the letter "f , perhaps in the sentence "The quick 
brown fox jumped over the lazy dog", as the partially typed phrase 100 might 
appear on display 90 of a companion device 80. 

10 Preferably the calibration phase of software routine 285 is user-friendly. 
Accordingly, routine 285 in essence moves or relocates the virtual keyboard to 
under the user's fingers. Such procedure may be carried out by mapping the 
image obtained from sensor 20 to the fingers of the template, and then mapping 
the touched keys to the natural position for the user, which natural position was 

15 determined during the template construction phase. 

The calibration step defines an initial state or rest position, and maps the user's 
fingers at rest position to specific keys on the keyboard. As shown in Fig. 1 B, the 
"keys" 107 that are touched or very nearby (but not pressed) preferably are 
20 highlighted on a soft-keyboard 1 05 displayed on screen 90 of companion device 
80, assuming of course that a screen 90 is available. This rest position will also 
be the position that the user's fingers assume at the end of a typing burst. 

During actual typing, routine 285 senses the user's fingers and maps finger 
25 movements to correct keys on a virtual keyboard. Before starting this phase of 
the algorithm, the relevant companion device 80 application will have been put 
into text input mode and will be ready to accept keyboard events (e.g. KEYUP 
and KEYDOWN). 

30 Routine 285 (or equivalent) may be implemented in many ways. In the preferred 
embodiment, routine 285 will use three modules. A "classifier" module is used 
to map clusters in each frame to userfingers. A "tracker" module is used to track 
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movement of active fingers by searching for a key stroke finger motion and by 
determining coordinates of the point of impact between the user's finger and a 
location on a virtual keyboard or other work surface. A third "mapper" module 
maps the impact point of a user finger to a specific key on the virtual keyboard 
5 and sends a key event to the companion device 80. These exemplary modules 
will now be described in further detail. 

The role of the classifier module is to make sense of the contour map of the 
scene generated by sensor 20 at each frame of optically acquired data. The 

1 0 cluster module will identify clusters that have certain common properties such as 
being part of the same surface. Importantly, the classifier will label each cluster 
so that the same cluster can be identified from other clusters in successive 
frames of acquired data. The classifier also determines the boundaries of each 
cluster, and specifically determines the tip of each cluster, which tip maps to the 

1 5 tip of user fingers. The goal is not recognition of user fingers per se, in that for 
all intent and purpose the user could be holding a stick or stylus that is used to 
press virtual keys or virtual locations of keys. Thus the above-described 
template is used primarily to give meaning to these clusters and to assist in 
forming the clusters. 

20 

One method of clustering or locating clusters is to use a nearest neighbor 
condition to form nearest neighbor partitions, in which each partition maps to 
each finger of the user. Such mapping would result in five partitions for the 
user's left hand, and five partitions for the user's right hand, in which left hand 
25 and right hand partitions can be treated separately. 

One method of partition formation is based on Llyod's algorithm. Details of this 
algorithm, which is well known in the field of image processing, may be found in 
the text Vector Quantization and Signal Compression by Allen Gersho and 
30 Robert Gray, see page 362. By way of example, let C, = {q; i=1 ,..5} be the set 
of partitions for one hand. In each partition a set of points P, t = {r: d(r, q) < d(r,Cj); 
for all j <> i } is defined, in which function d() is a measure of the distance 
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between two points in the set. If d(r, q) = d(r,Cj), the "tie" can be broken by 
placing the point in the set with a lower index. For two points a and b, d(a,b) can 
be defined as (x a -x b ) 2 +(y a -y b ) 2 +(z a -z b ) 2 , where x, y and z are the axis- 
measurements obtained from sensor 20. A function center(P i t ) can be defined 
5 as the center of gravity or centroid of the points in P it . Next define C t+1 = 
{center(P lt ); i=1,..5}. Using the new centroids, P it+1 can be found, as above. 
Iteratation is continued (e.g., by routine 285 or equivalent) until the membership 
of the two successive P, sets remain unchanged. Typically, the iteration 
converges in 3-4 iterations, and points in the final set P, are the clusters of points 
10 for each user finger. In this method, the ultimate goal of the classifier is not 
recognition of user fingers per se, but rather to determine which key was struck 
by a user finger. This observation enables the classifier to tolerate clustering 
inaccuracies in the periphery of a typing region that do not impact the 
performance of the system. 

15 

The tracker module will now be more fully described with respect to the matrices 
shown in Figs. 7A-70, in which the clusters are shaded as an aide to visually 
understanding the data. Perceived clusters are preferably input to a tracker 
20 module that will keep track of the movement of each cluster. The tracker module 
is especially alert for relatively rapid up and down movements, and will compute 
velocities and directions of the clusters. 

Figs. 7D-7K depict matrix tables showing a sequence of images obtained as the 
25 user's second finger rises upward and then moves downward to strike at a 
(virtual) key beneath the end of the finger. Preferably the tip of each cluster that 
is closely monitored by the tracker module will have been identified by the 
classifier module. In actual images, other user fingers may also move slightly, 
but in the example being described, the classifier determines that the rate of 
30 acceleration of the left forefinger (finger 2) is noticeably higher than the 
movements of the other fingers. 
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In Figs. 7D-7E, a pointing arrow is added to show the direction and the tip of the 
perceived cluster (e.g., user finger). Cluster or finger movement is upward in 
Figs. 7D-7F, with Fig. 7F representing a maximum upward position of the user's 
finger, e.g., a maximum Y-axis location as determined by sensor 20 acquired 
5 data. In Figs. 7G-7H, the cluster or finger is now moving downward, e.g., toward 
the virtual keyboard 50 or work surface 60. In Fig. 71, contact of the user's finger 
with a virtual key or key location on a work surface is perceived. 

Vertical velocity of a finger tip may be computed by routine 285 (or other routine) 
10 in several ways. In a preferred embodiment, the tracker module computes 
vertical velocity of a user's fingertip (identified by the classifier) by dividing the 
difference between the highest and the lowest position of the fingertip by the 
number of frames acquired during the sequence. The velocity is computed in 
terms of Y-axis resolution by number of frames, which is independent of the 
1 5 frame rate per second. To register a key strike, this computed Y-axis velocity 
must be equal or higher than a threshold velocity. The threshold velocity is a 
parameter that used by software 285, and preferably is user-adjustable during 
the personalization step. 

20 Figs. 7J-70 depict matrix tables in which a more complex sequence showing 
movement of the user's left forefinger (finger 2) in a down-and-back direction. 
In Fig. 70, this finger motion is shown culminating in a key stroke on a key in the 
first row of the virtual keyboard (or location on a work surface in front of device 
80 where such virtual key would otherwise be found). 

25 

Referring now to the mapper module, the tracker module will signal the mapper 
module when it determines that a keystroke has been detected, and the tracker 
module passes the cluster tip (X.Y.Z) coordinates of the cluster tip. The mapper 
module uses the Z-axis value to determine the row location on the virtual 
30 keyboard, and uses the X-axis and Y-axis values to determine the key within the 
row. Referring for example to Fig. 1 A, a coordinate (X.Y.Z) location (7,0,3) might 
signify the letter "T" on a virtual keyboard. Again it is understood that the various 
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modules preferably comprise portions of software routine 285, although other 
routines including routines executed other than by CPU 285 may instead be 
used. 

5 Modifications and variations may be made to the disclosed embodiments 
without departing from the subject and spirit of the invention as defined by the 
following claims. For example, if desired more than one sensor may be 
employed to acquire three-dimensional position information. 
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WHAT IS CLAIMED IS : 

1 . A method for a user to manually input data to a companion 
system using a virtual input device, the method comprising the following 
steps: 

5 (a) providing a sensor able to capture three-dimensional positional 

information of relative position of at least one user digit with respect to a work 
surface upon which the user may input data with said user digit; 

(b) processing information captured by said sensor to determine 
whether said user digit contacted a portion of said work surface and if 

10 contacted to determine location of said contact; and 

(c) outputting to said companion system digital information 
commensurate with said location of said contact. 

2. The method of claim 1 , wherein said sensor captures said 

15 information using time-of-flight from sensor to a surface portion of said user 
digit. 

3. The method of claim 1 , wherein step (a) includes providing a 
solid state sensor having an aspect ratio less than about 2:1. 

20 

4. The method of claim 1 , wherein said user digit is selected from a 
group consisting of (i) a finger on a hand of a user, and (ii) a stylus instrument 
controlled by a hand of a user. 

25 5. The method of claim 1 , wherein said work surface is selected 

from a group consisting of (i) three-dimensional space, (ii) a physical planar 
surface, (iii) a substrate, <iv) a substrate bearing a user-viewable image of an 
actual keyboard, (v) a substrate upon which is projected a user-viewable 
image of an actual keyboard, (v) a substrate upon which is projected a user- 

30 viewable typing guide, (vii) a passive substrate bearing a user-viewable image 
of an actual keyboard and including passive key-like regions that provide 
tactile feedback when pressed by said user digit, and (viii) a substrate that 
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when deployed for use measures at least 6" x 12" but when not used 
measures less than about 6" x 8". 

6. The method of claim 1 , further including providing said a user of 
5 said method with feedback guiding placement of said user digit, said feedback 
including at least one type of feedback selected from a group consisting of (i) 
tactile feedback emulating user-typing upon an actual keyboard, (ii) audible 
feedback generated by said companion device, (iii) visual feedback displayed 
on said companion device depicting an image of at least one keyboard key, 
1 0 (iv) visual feedback displayed on said companion device depicted keyboard 
keys in which keys adjacent to said digit are visually distinguished from keys 
touched by said digit, and (iii) visual feedback displayed on said companion 
device depicting data input by said user digit. 

1 5 7. The method of claim 1 , wherein said data includes at least one 

type of data selected from a group consisting of (i) digital code representing 
an alphanumeric character, (ii) digital code representing a command, (iii) 
digital code representing a locus of points traced by said user digit. 

20 8. The method of claim 1 , wherein step (c) includes determining 

spatial location of a distal portion of said user digit relative to location on said 
work surface using at least one of (i) three-dimensional location of said distal 
portion, (ii) velocity information for said distal portion in at least one direction, 
(iii) matching acquired information to template models of said user digit, (iv) 

25 hysteresis information processing, and (v) knowledge of language of data 
being input. 

9. The method of claim 1 , further including mapping three- 
dimensional positions of a distal tip portion of said user digit to keys on an 
30 actual keyboard, and identifying which of said keys, had they been present on 
said work surface, would have been typed upon. 
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1 0. The method of claim 1 , wherein said user digit includes fingers 
on a hand of a user of said method, and wherein data is captured by said 
sensor in frames, and step (b) includes processing data acquired in 
successive frames to determine three-dimensional position information as to 

5 at least two fingers on said user's hand including a vertical velocity component 
of at least two fingers. 

1 1 . The method of claim 1 , wherein said companion system includes 
at least one device selected from a group consisting of (i) a PDA, (ii) a 

10 wireless telephone, (iii) a set-top box, (iv) a computer, and (v) an appliance 
adapted to accept input data. 

12. A system for use with a companion device adapted to receive 
digital input manually provided by a user, comprising: 

15 a sensor able to capture three-dimensional positional information of 

relative position of at least one user digit with respect to a work surface upon 
which the user may input data to said companion device using said user digit; 

a processor to process information captured by said sensor to 
determine whether said user digit contacted a portion of said work surface and 
20 if contacted to determine location of said contact; 

said processor outputting to said companion system digital information 
commensurate with said location of said contact. 

13. The system of claim 12, wherein said sensor uses an energy 
25 emitting device having an aspect ratio less than about 2:1, and said 

information is captured using time-of-flight from sensor to a surface portion of 
said user digit. 

14. The system of claim 12, wherein said user digit is selected from 
30 a group consisting of (i) a finger on a hand of a user, and (ii) a stylus 

instrument controlled by a hand of a user. 
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15. The system of claim 12, wherein said work surface is selected 
from a group consisting of (i) three-dimensional space, (ii) a physical planar 
surface, (iii) a substrate, (iv) a substrate bearing a user-viewable image of an 
actual keyboard, (v) a substrate upon which is projected a user-viewable 

5 image of an actual keyboard, (v) a substrate upon which is projected a user- 
viewable typing guide, (vii) a passive substrate bearing a user-viewable image 
of an actual keyboard and including passive key-like regions that provide 
tactile feedback when pressed by said user digit, and (viii) a substrate that, 
when deployed for use measures at least 6" x 12" but when not used 
10 measures less than about 6" x 8". 

16. The system of claim 12, wherein said system provides a user of 
said system with feedback guiding placement of said user digit, said feedback 
including at least one type of feedback selected from a group consisting of (i) 

15 tactile feedback emulating user-typing upon an actual keyboard, (ii) audible 
feedback generated by said companion device, (iii) visual feedback displayed 
on said companion device depicting an image of at least one keyboard key, 
(iv) visual feedback displayed on said companion device depicted keyboard 
keys in which keys adjacent to said digit are visually distinguished from keys 

20 touched by said digit, and (iii) visual feedback displayed on said companion 
device depicting data input by said user digit. 

16. The system pf claim 12, wherein said data includes at least one 
type of data selected from a group consisting of (i) digital code representing 

25 an alphanumeric character, (ii) digital code representing a command, (iii) 
digital code representing a locus of points traced by said user digit. 

17. The system of claim 12, wherein said processor determines 
spatial location of a distal portion of said user digit relative to location on said 

30 work surface using at least one of (i) three-dimensional location of said distal 
portion, (ii) velocity information for said distal portion in at least one direction, 
(iii) matching acquired information to template models of said user digit, (iv) 
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hysteresis information processing, and (v) knowledge of language of data 
being input. 

18. The system of claim 12, wherein said processor maps three- 
5 dimensional positions of a distal tip portion of said user digit to keys on an 
actual keyboard, and identifies which of said keys, had they been present on 
said work surface, would have been typed upon. 



10 input device, comprising: 

a sensor able to capture three-dimensional positional information of 
relative position of at least one user digit with respect to a work surface upon 
which the user may input data to said companion device using said user digit; 



15 determine whether said user digit contacted a portion of said work surface and 
if contacted to determine location of said contact; and 

a companion device, coupled to receive digital information that is 
commensurate with said location of said contact output from said processor. 



a group consisting of (i) a finger on a hand of a user, and (ii) a stylus 
instrument controlled by a hand of a user, and wherein said work surface is 
selected from a group consisting of (i) three-dimensional space, (ii) a physical 
planar surface, (iii) a substrate, (iv) a substrate bearing a user-viewable image 

25 of an actual keyboard, (v) a substrate upon which is projected a user-viewable 
image of an actual keyboard, (v) a substrate upon which is projected a user- 
viewable typing guide, (vii) a passive substrate bearing a user-viewable image 
of an actual keyboard and including passive key-like regions that emit an 
audible sound when pressed by said user digit, and (viii) a substrate that 

30 when deployed for use measures at least 6" x 12" but when not used 
measures less than about 6" x 8". 



19. A system permitting a user to manually input data using a virtual 



a processor to process information captured by said sensor to 



20 



20. The system of claim 1 9, wherein said user digit is selected from 
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